home *** CD-ROM | disk | FTP | other *** search
/ Shareware Grab Bag / Shareware Grab Bag.iso / 090 / byte0387.arc / DAWSON.ARC / SIMPRIM.C < prev    next >
Unknown  |  1985-07-12  |  7.9 KB

open in: MacOS 8.1     |     Win98     |     DOS

view JSON data     |     view as text

This file was not able to be converted.
This format is not currently supported by dexvert.

ConfidenceProgramDetectionMatch TypeSupport
66% dexvert Compact Compressed (Unix) (archive/compact) ext Supported
100% file data default
100% gt2 Kopftext: 'cat simprin.c' default (weak)



hex view
+--------+-------------------------+-------------------------+--------+--------+
|00000000| 63 61 74 20 73 69 6d 70 | 72 69 6e 2e 63 08 20 08 |cat simp|rin.c. .|
|00000010| 08 20 08 08 20 08 08 20 | 08 69 6d 2e 63 0d 0a 00 |. .. .. |.im.c...|
|00000020| 00 00 00 2f 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |.../****|********|
|00000030| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000040| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000050| 2a 5c 0d 0a 00 00 00 00 | 2a 20 09 09 09 09 09 20 |*\......|* ..... |
|00000060| 20 20 20 20 20 2a 0d 0a | 00 00 00 00 2a 20 20 20 | *..|....* |
|00000070| 73 69 6d 70 72 69 6d 2e | 63 20 3d 20 49 6d 61 67 |simprim.|c = Imag|
|00000080| 65 20 70 72 6f 63 65 73 | 73 69 6e 67 20 70 72 69 |e proces|sing pri|
|00000090| 6d 69 74 69 76 65 73 2e | 20 20 2a 0d 0a 00 00 00 |mitives.| *.....|
|000000a0| 00 2a 20 20 20 46 6f 72 | 20 53 69 6d 70 6c 65 20 |.* For| Simple |
|000000b0| 49 4d 61 67 65 20 50 72 | 6f 63 65 73 73 69 6e 67 |IMage Pr|ocessing|
|000000c0| 20 50 61 63 6b 61 67 65 | 2e 20 20 20 20 20 20 2a | Package|. *|
|000000d0| 0d 0a 00 00 00 00 2a 20 | 20 20 43 6f 70 79 72 69 |......* | Copyri|
|000000e0| 67 68 74 20 28 63 29 20 | 31 39 38 37 2c 20 42 65 |ght (c) |1987, Be|
|000000f0| 6e 6a 61 6d 69 6e 20 4d | 2e 20 44 61 77 73 6f 6e |njamin M|. Dawson|
|00000100| 20 20 20 20 2a 0d 0a 00 | 00 00 00 2a 20 20 20 20 | *...|...* |
|00000110| 20 20 45 64 69 74 20 56 | 65 72 73 69 6f 6e 3a 20 | Edit V|ersion: |
|00000120| 31 2e 31 20 3a 20 4a 61 | 6e 2d 32 39 2d 38 37 09 |1.1 : Ja|n-29-87.|
|00000130| 20 20 20 20 20 20 2a 0d | 0a 00 00 00 00 2a 20 09 | *.|.....* .|
|00000140| 09 09 09 09 20 20 20 20 | 20 20 2a 0d 0a 00 00 00 |.... | *.....|
|00000150| 00 5c 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |.\******|********|
|00000160| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000170| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2f |********|*******/|
|00000180| 0d 0a 00 00 00 00 0d 0a | 00 00 00 00 23 69 6e 63 |........|....#inc|
|00000190| 6c 75 64 65 20 22 73 69 | 6d 70 70 2e 68 22 0d 0a |lude "si|mpp.h"..|
|000001a0| 00 00 00 00 0d 0a 00 00 | 00 00 65 78 74 65 72 6e |........|..extern|
|000001b0| 20 63 68 61 72 20 2a 6d | 61 6c 6c 6f 63 28 29 3b | char *m|alloc();|
|000001c0| 0d 0a 00 00 00 00 0d 0a | 00 00 00 00 0d 0a 00 00 |........|........|
|000001d0| 00 00 2f 2a 20 72 65 61 | 64 5f 68 6c 69 6e 65 20 |../* rea|d_hline |
|000001e0| 3d 20 52 65 61 64 20 68 | 6f 72 69 7a 6f 6e 74 61 |= Read h|orizonta|
|000001f0| 6c 20 6c 69 6e 65 20 6f | 66 20 70 69 78 65 6c 73 |l line o|f pixels|
|00000200| 2c 20 73 74 61 72 74 69 | 6e 67 20 61 74 20 78 2c |, starti|ng at x,|
|00000210| 79 20 61 6e 64 20 6f 66 | 0d 0a 00 00 00 00 20 2a |y and of|...... *|
|00000220| 20 6c 65 6e 67 74 68 20 | 6e 20 69 6e 74 6f 20 74 | length |n into t|
|00000230| 68 65 20 62 75 66 66 65 | 72 20 70 6f 69 6e 74 65 |he buffe|r pointe|
|00000240| 64 20 74 6f 20 62 79 20 | 62 70 0d 0a 00 00 00 00 |d to by |bp......|
|00000250| 20 2a 2f 0d 0a 00 00 00 | 00 69 6e 74 20 72 65 61 | */.....|.int rea|
|00000260| 64 5f 68 6c 69 6e 65 28 | 78 2c 79 2c 6e 2c 62 70 |d_hline(|x,y,n,bp|
|00000270| 29 0d 0a 00 00 00 00 69 | 6e 74 20 78 2c 79 3b 09 |)......i|nt x,y;.|
|00000280| 09 09 2f 2a 20 53 63 72 | 65 65 6e 20 73 74 61 72 |../* Scr|een star|
|00000290| 74 69 6e 67 20 6c 6f 63 | 61 74 69 6f 6e 20 2a 2f |ting loc|ation */|
|000002a0| 0d 0a 00 00 00 00 72 65 | 67 69 73 74 65 72 20 69 |......re|gister i|
|000002b0| 6e 74 20 6e 3b 09 09 09 | 2f 2a 20 4e 75 6d 62 65 |nt n;...|/* Numbe|
|000002c0| 72 20 6f 66 20 70 69 78 | 65 6c 73 20 74 6f 20 72 |r of pix|els to r|
|000002d0| 65 61 64 20 2a 2f 0d 0a | 00 00 00 00 72 65 67 69 |ead */..|....regi|
|000002e0| 73 74 65 72 20 50 49 58 | 45 4c 20 2a 62 70 3b 09 |ster PIX|EL *bp;.|
|000002f0| 09 2f 2a 20 50 6f 69 6e | 74 65 72 20 74 6f 20 70 |./* Poin|ter to p|
|00000300| 69 78 65 6c 20 62 75 66 | 66 65 72 20 2a 2f 0d 0a |ixel buf|fer */..|
|00000310| 00 00 00 00 7b 0d 0a 00 | 00 00 00 0d 0a 00 00 00 |....{...|........|
|00000320| 00 23 69 66 64 65 66 20 | 43 48 45 43 4b 0d 0a 00 |.#ifdef |CHECK...|
|00000330| 00 00 00 09 69 66 20 28 | 28 78 20 3c 20 58 53 54 |....if (|(x < XST|
|00000340| 41 52 54 29 20 7c 7c 20 | 28 78 20 3e 20 58 45 4e |ART) || |(x > XEN|
|00000350| 44 29 29 20 7b 0d 0a 00 | 00 00 00 09 09 70 72 69 |D)) {...|.....pri|
|00000360| 6e 74 66 28 22 3c 72 65 | 61 64 5f 68 6c 69 6e 65 |ntf("<re|ad_hline|
|00000370| 3e 20 58 20 61 64 64 72 | 65 73 73 20 6f 75 74 20 |> X addr|ess out |
|00000380| 6f 66 20 72 61 6e 67 65 | 21 5c 6e 22 29 3b 0d 0a |of range|!\n");..|
|00000390| 00 00 00 00 09 09 72 65 | 74 75 72 6e 28 45 52 52 |......re|turn(ERR|
|000003a0| 4f 52 29 3b 0d 0a 00 00 | 00 00 09 7d 0d 0a 00 00 |OR);....|...}....|
|000003b0| 00 00 09 69 66 20 28 28 | 79 20 3c 20 59 53 54 41 |...if ((|y < YSTA|
|000003c0| 52 54 29 20 7c 7c 20 28 | 79 20 3e 20 59 45 4e 44 |RT) || (|y > YEND|
|000003d0| 29 29 20 7b 0d 0a 00 00 | 00 00 09 09 70 72 69 6e |)) {....|....prin|
|000003e0| 74 66 28 22 3c 72 65 61 | 64 5f 68 6c 69 6e 65 3e |tf("<rea|d_hline>|
|000003f0| 20 59 20 61 64 64 72 65 | 73 73 20 6f 75 74 20 6f | Y addre|ss out o|
|00000400| 66 20 72 61 6e 67 65 20 | 21 5c 6e 22 29 3b 0d 0a |f range |!\n");..|
|00000410| 00 00 00 00 09 09 72 65 | 74 75 72 6e 28 45 52 52 |......re|turn(ERR|
|00000420| 4f 52 29 3b 0d 0a 00 00 | 00 00 09 7d 0d 0a 00 00 |OR);....|...}....|
|00000430| 00 00 09 69 66 20 28 28 | 6e 20 3c 20 30 29 20 7c |...if ((|n < 0) ||
|00000440| 7c 20 28 6e 20 3e 20 58 | 53 49 5a 45 2d 78 29 29 || (n > X|SIZE-x))|
|00000450| 20 7b 0d 0a 00 00 00 00 | 09 09 70 72 69 6e 74 66 | {......|..printf|
|00000460| 28 22 3c 72 65 61 64 5f | 68 6c 69 6e 65 3e 20 57 |("<read_|hline> W|
|00000470| 72 6f 6e 67 20 6e 75 6d | 62 65 72 20 6f 66 20 70 |rong num|ber of p|
|00000480| 69 78 65 6c 73 21 5c 6e | 22 29 3b 0d 0a 00 00 00 |ixels!\n|");.....|
|00000490| 00 09 09 72 65 74 75 72 | 6e 28 45 52 52 4f 52 29 |...retur|n(ERROR)|
|000004a0| 3b 0d 0a 00 00 00 00 09 | 7d 0d 0a 00 00 00 00 23 |;.......|}......#|
|000004b0| 65 6e 64 69 66 0d 0a 00 | 00 00 00 0d 0a 00 00 00 |endif...|........|
|000004c0| 00 09 77 68 69 6c 65 20 | 28 6e 2d 2d 29 20 2a 62 |..while |(n--) *b|
|000004d0| 70 2b 2b 20 3d 20 72 65 | 61 64 5f 70 69 78 65 6c |p++ = re|ad_pixel|
|000004e0| 28 78 2b 2b 2c 79 29 3b | 0d 0a 00 00 00 00 09 72 |(x++,y);|.......r|
|000004f0| 65 74 75 72 6e 28 4f 4b | 29 3b 0d 0a 00 00 00 00 |eturn(OK|);......|
|00000500| 7d 0d 0a 00 00 00 00 0d | 0a 00 00 00 00 2f 2a 20 |}.......|...../* |
|00000510| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|00000520| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|00000530| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|00000540| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|00000550| 20 2a 2f 0d 0a 00 00 00 | 00 0d 0a 00 00 00 00 2f | */.....|......./|
|00000560| 2a 20 77 72 69 74 65 5f | 68 6c 69 6e 65 20 3d 20 |* write_|hline = |
|00000570| 57 72 69 74 65 20 61 20 | 62 75 66 66 65 72 2c 20 |Write a |buffer, |
|00000580| 62 70 20 69 6e 74 6f 20 | 61 20 68 6f 72 69 7a 6f |bp into |a horizo|
|00000590| 6e 74 61 6c 20 6c 69 6e | 65 20 6f 66 20 69 6d 61 |ntal lin|e of ima|
|000005a0| 67 65 20 6d 65 6d 6f 72 | 79 0d 0a 00 00 00 00 20 |ge memor|y...... |
|000005b0| 2a 20 6d 65 6d 6f 72 79 | 20 70 69 78 65 6c 73 2c |* memory| pixels,|
|000005c0| 20 73 74 61 72 74 69 6e | 67 20 61 74 20 78 2c 79 | startin|g at x,y|
|000005d0| 20 61 6e 64 20 6f 66 20 | 6c 65 6e 67 74 68 20 6e | and of |length n|
|000005e0| 2e 0d 0a 00 00 00 00 20 | 2a 2f 0d 0a 00 00 00 00 |....... |*/......|
|000005f0| 0d 0a 00 00 00 00 77 72 | 69 74 65 5f 68 6c 69 6e |......wr|ite_hlin|
|00000600| 65 28 78 2c 79 2c 6e 2c | 62 70 29 0d 0a 00 00 00 |e(x,y,n,|bp).....|
|00000610| 00 69 6e 74 20 78 2c 79 | 3b 09 09 09 2f 2a 20 53 |.int x,y|;.../* S|
|00000620| 63 72 65 65 6e 20 73 74 | 61 72 74 69 6e 67 20 6c |creen st|arting l|
|00000630| 6f 63 61 74 69 6f 6e 20 | 2a 2f 0d 0a 00 00 00 00 |ocation |*/......|
|00000640| 72 65 67 69 73 74 65 72 | 20 69 6e 74 20 6e 3b 09 |register| int n;.|
|00000650| 09 09 2f 2a 20 4e 75 6d | 62 65 72 20 6f 66 20 70 |../* Num|ber of p|
|00000660| 69 78 65 6c 73 20 74 6f | 20 77 72 69 74 65 20 2a |ixels to| write *|
|00000670| 2f 0d 0a 00 00 00 00 72 | 65 67 69 73 74 65 72 20 |/......r|egister |
|00000680| 50 49 58 45 4c 20 2a 62 | 70 3b 09 09 2f 2a 20 50 |PIXEL *b|p;../* P|
|00000690| 6f 69 6e 74 65 72 20 74 | 6f 20 70 69 78 65 6c 20 |ointer t|o pixel |
|000006a0| 62 75 66 66 65 72 20 2a | 2f 0d 0a 00 00 00 00 7b |buffer *|/......{|
|000006b0| 0d 0a 00 00 00 00 0d 0a | 00 00 00 00 23 69 66 64 |........|....#ifd|
|000006c0| 65 66 20 43 48 45 43 4b | 0d 0a 00 00 00 00 09 69 |ef CHECK|.......i|
|000006d0| 66 20 28 28 78 20 3c 20 | 58 53 54 41 52 54 29 20 |f ((x < |XSTART) |
|000006e0| 7c 7c 20 28 78 20 3e 20 | 58 45 4e 44 29 29 20 7b ||| (x > |XEND)) {|
|000006f0| 0d 0a 00 00 00 00 09 09 | 70 72 69 6e 74 66 28 22 |........|printf("|
|00000700| 3c 77 72 69 74 65 5f 68 | 6c 69 6e 65 3e 20 58 20 |<write_h|line> X |
|00000710| 61 64 64 72 65 73 73 20 | 6f 75 74 20 6f 66 20 72 |address |out of r|
|00000720| 61 6e 67 65 21 5c 6e 22 | 29 3b 0d 0a 00 00 00 00 |ange!\n"|);......|
|00000730| 09 09 72 65 74 75 72 6e | 28 45 52 52 4f 52 29 3b |..return|(ERROR);|
|00000740| 0d 0a 00 00 00 00 09 7d | 0d 0a 00 00 00 00 09 69 |.......}|.......i|
|00000750| 66 20 28 28 79 20 3c 20 | 59 53 54 41 52 54 29 20 |f ((y < |YSTART) |
|00000760| 7c 7c 20 28 79 20 3e 20 | 59 45 4e 44 29 29 20 7b ||| (y > |YEND)) {|
|00000770| 0d 0a 00 00 00 00 09 09 | 70 72 69 6e 74 66 28 22 |........|printf("|
|00000780| 3c 77 72 69 74 65 5f 68 | 6c 69 6e 65 3e 20 59 20 |<write_h|line> Y |
|00000790| 61 64 64 72 65 73 73 20 | 6f 75 74 20 6f 66 20 72 |address |out of r|
|000007a0| 61 6e 67 65 21 5c 6e 22 | 29 3b 0d 0a 00 00 00 00 |ange!\n"|);......|
|000007b0| 09 09 72 65 74 75 72 6e | 28 45 52 52 4f 52 29 3b |..return|(ERROR);|
|000007c0| 0d 0a 00 00 00 00 09 7d | 0d 0a 00 00 00 00 09 69 |.......}|.......i|
|000007d0| 66 20 28 28 6e 20 3c 20 | 30 29 20 7c 7c 20 28 6e |f ((n < |0) || (n|
|000007e0| 20 3e 20 58 53 49 5a 45 | 2d 78 29 29 20 7b 0d 0a | > XSIZE|-x)) {..|
|000007f0| 00 00 00 00 09 09 70 72 | 69 6e 74 66 28 22 3c 77 |......pr|intf("<w|
|00000800| 72 69 74 65 5f 68 6c 69 | 6e 65 3e 20 57 72 6f 6e |rite_hli|ne> Wron|
|00000810| 67 20 6e 75 6d 62 65 72 | 20 6f 66 20 70 69 78 65 |g number| of pixe|
|00000820| 6c 73 21 5c 6e 22 29 3b | 0d 0a 00 00 00 00 09 09 |ls!\n");|........|
|00000830| 72 65 74 75 72 6e 28 45 | 52 52 4f 52 29 3b 0d 0a |return(E|RROR);..|
|00000840| 00 00 00 00 09 7d 0d 0a | 00 00 00 00 23 65 6e 64 |.....}..|....#end|
|00000850| 69 66 0d 0a 00 00 00 00 | 0d 0a 00 00 00 00 09 77 |if......|.......w|
|00000860| 68 69 6c 65 20 28 6e 2d | 2d 29 20 77 72 69 74 65 |hile (n-|-) write|
|00000870| 5f 70 69 78 65 6c 28 78 | 2b 2b 2c 79 2c 2a 62 70 |_pixel(x|++,y,*bp|
|00000880| 2b 2b 29 3b 0d 0a 00 00 | 00 00 09 72 65 74 75 72 |++);....|...retur|
|00000890| 6e 28 4f 4b 29 3b 0d 0a | 00 00 00 00 7d 0d 0a 00 |n(OK);..|....}...|
|000008a0| 00 00 00 0d 0a 00 00 00 | 00 2f 2a 20 3d 3d 3d 3d |........|./* ====|
|000008b0| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|000008c0| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|000008d0| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|000008e0| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 20 2a 2f 0d |========|==== */.|
|000008f0| 0a 00 00 00 00 0d 0a 00 | 00 00 00 2f 2a 20 72 65 |........|.../* re|
|00000900| 61 64 5f 76 6c 69 6e 65 | 20 3d 20 52 65 61 64 20 |ad_vline| = Read |
|00000910| 76 65 72 74 69 63 61 6c | 20 6c 69 6e 65 20 6f 66 |vertical| line of|
|00000920| 20 70 69 78 65 6c 73 20 | 73 74 61 72 74 69 6e 67 | pixels |starting|
|00000930| 20 61 74 20 6c 6f 63 61 | 74 69 6f 6e 20 78 2c 79 | at loca|tion x,y|
|00000940| 0d 0a 00 00 00 00 20 2a | 20 61 6e 64 20 6f 66 20 |...... *| and of |
|00000950| 6c 65 6e 67 74 68 20 6e | 20 69 6e 74 6f 20 62 75 |length n| into bu|
|00000960| 66 66 65 72 20 62 70 0d | 0a 00 00 00 00 20 2a 2f |ffer bp.|..... */|
|00000970| 0d 0a 00 00 00 00 69 6e | 74 20 72 65 61 64 5f 76 |......in|t read_v|
|00000980| 6c 69 6e 65 28 78 2c 79 | 2c 6e 2c 62 70 29 0d 0a |line(x,y|,n,bp)..|
|00000990| 00 00 00 00 69 6e 74 20 | 78 2c 79 3b 09 09 09 2f |....int |x,y;.../|
|000009a0| 2a 20 53 63 72 65 65 6e | 20 73 74 61 72 74 69 6e |* Screen| startin|
|000009b0| 67 20 6c 6f 63 61 74 69 | 6f 6e 20 2a 2f 0d 0a 00 |g locati|on */...|
|000009c0| 00 00 00 72 65 67 69 73 | 74 65 72 20 69 6e 74 20 |...regis|ter int |
|000009d0| 6e 3b 09 09 09 2f 2a 20 | 4e 75 6d 62 65 72 20 6f |n;.../* |Number o|
|000009e0| 66 20 70 69 78 65 6c 73 | 20 74 6f 20 72 65 61 64 |f pixels| to read|
|000009f0| 20 2a 2f 0d 0a 00 00 00 | 00 72 65 67 69 73 74 65 | */.....|.registe|
|00000a00| 72 20 50 49 58 45 4c 20 | 2a 62 70 3b 09 09 2f 2a |r PIXEL |*bp;../*|
|00000a10| 20 50 6f 69 6e 74 65 72 | 20 74 6f 20 70 69 78 65 | Pointer| to pixe|
|00000a20| 6c 20 62 75 66 66 65 72 | 20 2a 2f 0d 0a 00 00 00 |l buffer| */.....|
|00000a30| 00 7b 0d 0a 00 00 00 00 | 0d 0a 00 00 00 00 23 69 |.{......|......#i|
|00000a40| 66 64 65 66 20 43 48 45 | 43 4b 0d 0a 00 00 00 00 |fdef CHE|CK......|
|00000a50| 09 69 66 20 28 28 78 20 | 3c 20 58 53 54 41 52 54 |.if ((x |< XSTART|
|00000a60| 29 20 7c 7c 20 28 78 20 | 3e 20 58 45 4e 44 29 29 |) || (x |> XEND))|
|00000a70| 20 7b 0d 0a 00 00 00 00 | 09 09 70 72 69 6e 74 66 | {......|..printf|
|00000a80| 28 22 3c 72 65 61 64 5f | 76 6c 69 6e 65 3e 20 58 |("<read_|vline> X|
|00000a90| 20 61 64 64 72 65 73 73 | 20 6f 75 74 20 6f 66 20 | address| out of |
|00000aa0| 72 61 6e 67 65 21 5c 6e | 22 29 3b 0d 0a 00 00 00 |range!\n|");.....|
|00000ab0| 00 09 09 72 65 74 75 72 | 6e 28 45 52 52 4f 52 29 |...retur|n(ERROR)|
|00000ac0| 3b 0d 0a 00 00 00 00 09 | 7d 0d 0a 00 00 00 00 09 |;.......|}.......|
|00000ad0| 69 66 20 28 28 79 20 3c | 20 59 53 54 41 52 54 29 |if ((y <| YSTART)|
|00000ae0| 20 7c 7c 20 28 79 20 3e | 20 59 45 4e 44 29 29 20 | || (y >| YEND)) |
|00000af0| 7b 0d 0a 00 00 00 00 09 | 09 70 72 69 6e 74 66 28 |{.......|.printf(|
|00000b00| 22 3c 72 65 61 64 5f 76 | 6c 69 6e 65 3e 20 59 20 |"<read_v|line> Y |
|00000b10| 61 64 64 72 65 73 73 20 | 6f 75 74 20 6f 66 20 72 |address |out of r|
|00000b20| 61 6e 67 65 21 5c 6e 22 | 29 3b 0d 0a 00 00 00 00 |ange!\n"|);......|
|00000b30| 09 09 72 65 74 75 72 6e | 28 45 52 52 4f 52 29 3b |..return|(ERROR);|
|00000b40| 0d 0a 00 00 00 00 09 7d | 0d 0a 00 00 00 00 09 69 |.......}|.......i|
|00000b50| 66 20 28 28 6e 20 3c 20 | 30 29 20 7c 7c 20 28 6e |f ((n < |0) || (n|
|00000b60| 20 3e 20 59 53 49 5a 45 | 2d 79 29 29 20 7b 0d 0a | > YSIZE|-y)) {..|
|00000b70| 00 00 00 00 09 09 70 72 | 69 6e 74 66 28 22 3c 72 |......pr|intf("<r|
|00000b80| 65 61 64 5f 76 6c 69 6e | 65 3e 20 57 72 6f 6e 67 |ead_vlin|e> Wrong|
|00000b90| 20 6e 75 6d 62 65 72 20 | 6f 66 20 70 69 78 65 6c | number |of pixel|
|00000ba0| 73 21 5c 6e 22 29 3b 0d | 0a 00 00 00 00 09 09 72 |s!\n");.|.......r|
|00000bb0| 65 74 75 72 6e 28 45 52 | 52 4f 52 29 3b 0d 0a 00 |eturn(ER|ROR);...|
|00000bc0| 00 00 00 09 7d 0d 0a 00 | 00 00 00 23 65 6e 64 69 |....}...|...#endi|
|00000bd0| 66 0d 0a 00 00 00 00 0d | 0a 00 00 00 00 09 77 68 |f.......|......wh|
|00000be0| 69 6c 65 20 28 6e 2d 2d | 29 20 2a 62 70 2b 2b 20 |ile (n--|) *bp++ |
|00000bf0| 3d 20 72 65 61 64 5f 70 | 69 78 65 6c 28 78 2c 79 |= read_p|ixel(x,y|
|00000c00| 2b 2b 29 3b 0d 0a 00 00 | 00 00 09 72 65 74 75 72 |++);....|...retur|
|00000c10| 6e 28 4f 4b 29 3b 0d 0a | 00 00 00 00 7d 0d 0a 00 |n(OK);..|....}...|
|00000c20| 00 00 00 0d 0a 00 00 00 | 00 2f 2a 3d 3d 3d 3d 3d |........|./*=====|
|00000c30| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|00000c40| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|00000c50| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|00000c60| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 2a 2f 0d 0a 00 |========|===*/...|
|00000c70| 00 00 00 0d 0a 00 00 00 | 00 2f 2a 20 77 72 69 74 |........|./* writ|
|00000c80| 65 5f 76 6c 69 6e 65 20 | 3d 20 57 72 69 74 65 20 |e_vline |= Write |
|00000c90| 61 20 76 65 72 74 69 63 | 61 6c 20 6c 69 6e 65 20 |a vertic|al line |
|00000ca0| 6f 66 20 70 69 78 65 6c | 73 20 66 72 6f 6d 20 62 |of pixel|s from b|
|00000cb0| 75 66 66 65 72 20 62 70 | 20 69 6e 74 6f 0d 0a 00 |uffer bp| into...|
|00000cc0| 00 00 00 20 2a 20 66 72 | 61 6d 65 20 6d 65 6d 6f |... * fr|ame memo|
|00000cd0| 72 79 20 73 74 61 72 74 | 69 6e 67 20 61 74 20 6c |ry start|ing at l|
|00000ce0| 6f 63 61 74 69 6f 6e 20 | 78 2c 79 20 61 6e 64 20 |ocation |x,y and |
|00000cf0| 6f 66 20 6c 65 6e 67 68 | 74 20 6e 2e 0d 0a 00 00 |of lengh|t n.....|
|00000d00| 00 00 20 2a 2f 0d 0a 00 | 00 00 00 77 72 69 74 65 |.. */...|...write|
|00000d10| 5f 76 6c 69 6e 65 28 78 | 2c 79 2c 6e 2c 62 70 29 |_vline(x|,y,n,bp)|
|00000d20| 0d 0a 00 00 00 00 69 6e | 74 20 78 2c 79 3b 09 09 |......in|t x,y;..|
|00000d30| 09 2f 2a 20 53 63 72 65 | 65 6e 20 73 74 61 72 74 |./* Scre|en start|
|00000d40| 69 6e 67 20 6c 6f 63 61 | 74 69 6f 6e 20 2a 2f 0d |ing loca|tion */.|
|00000d50| 0a 00 00 00 00 72 65 67 | 69 73 74 65 72 20 69 6e |.....reg|ister in|
|00000d60| 74 20 6e 3b 09 09 09 2f | 2a 20 4e 75 6d 62 65 72 |t n;.../|* Number|
|00000d70| 20 6f 66 20 70 69 78 65 | 6c 73 20 74 6f 20 77 72 | of pixe|ls to wr|
|00000d80| 69 74 65 20 2a 2f 0d 0a | 00 00 00 00 72 65 67 69 |ite */..|....regi|
|00000d90| 73 74 65 72 20 50 49 58 | 45 4c 20 2a 62 70 3b 09 |ster PIX|EL *bp;.|
|00000da0| 09 2f 2a 20 50 6f 69 6e | 74 65 72 20 74 6f 20 70 |./* Poin|ter to p|
|00000db0| 69 78 65 6c 20 62 75 66 | 66 65 72 20 2a 2f 0d 0a |ixel buf|fer */..|
|00000dc0| 00 00 00 00 7b 0d 0a 00 | 00 00 00 0d 0a 00 00 00 |....{...|........|
|00000dd0| 00 23 69 66 64 65 66 20 | 43 48 45 43 4b 0d 0a 00 |.#ifdef |CHECK...|
|00000de0| 00 00 00 09 69 66 20 28 | 28 78 20 3c 20 58 53 54 |....if (|(x < XST|
|00000df0| 41 52 54 29 20 7c 7c 20 | 28 78 20 3e 20 58 45 4e |ART) || |(x > XEN|
|00000e00| 44 29 29 20 7b 0d 0a 00 | 00 00 00 09 09 70 72 69 |D)) {...|.....pri|
|00000e10| 6e 74 66 28 22 3c 77 72 | 69 74 65 5f 76 6c 69 6e |ntf("<wr|ite_vlin|
|00000e20| 65 3e 20 58 20 61 64 64 | 72 65 73 73 20 6f 75 74 |e> X add|ress out|
|00000e30| 20 6f 66 20 72 61 6e 67 | 65 21 5c 6e 22 29 3b 0d | of rang|e!\n");.|
|00000e40| 0a 00 00 00 00 09 09 72 | 65 74 75 72 6e 28 45 52 |.......r|eturn(ER|
|00000e50| 52 4f 52 29 3b 0d 0a 00 | 00 00 00 09 7d 0d 0a 00 |ROR);...|....}...|
|00000e60| 00 00 00 09 69 66 20 28 | 28 79 20 3c 20 59 53 54 |....if (|(y < YST|
|00000e70| 41 52 54 29 20 7c 7c 20 | 28 79 20 3e 20 59 45 4e |ART) || |(y > YEN|
|00000e80| 44 29 29 20 7b 0d 0a 00 | 00 00 00 09 09 70 72 69 |D)) {...|.....pri|
|00000e90| 6e 74 66 28 22 3c 77 72 | 69 74 65 5f 76 6c 69 6e |ntf("<wr|ite_vlin|
|00000ea0| 65 3e 20 59 20 61 64 64 | 72 65 73 73 20 6f 75 74 |e> Y add|ress out|
|00000eb0| 20 6f 66 20 72 61 6e 67 | 65 21 5c 6e 22 29 3b 0d | of rang|e!\n");.|
|00000ec0| 0a 00 00 00 00 09 09 72 | 65 74 75 72 6e 28 45 52 |.......r|eturn(ER|
|00000ed0| 52 4f 52 29 3b 0d 0a 00 | 00 00 00 09 7d 0d 0a 00 |ROR);...|....}...|
|00000ee0| 00 00 00 09 69 66 20 28 | 28 6e 20 3c 20 30 29 20 |....if (|(n < 0) |
|00000ef0| 7c 7c 20 28 6e 20 3e 20 | 59 53 49 5a 45 2d 79 29 ||| (n > |YSIZE-y)|
|00000f00| 29 20 7b 0d 0a 00 00 00 | 00 09 09 70 72 69 6e 74 |) {.....|...print|
|00000f10| 66 28 22 3c 77 72 69 74 | 65 5f 76 6c 69 6e 65 3e |f("<writ|e_vline>|
|00000f20| 20 57 72 6f 6e 67 20 6e | 75 6d 62 65 72 20 6f 66 | Wrong n|umber of|
|00000f30| 20 70 69 78 65 6c 73 21 | 5c 6e 22 29 3b 0d 0a 00 | pixels!|\n");...|
|00000f40| 00 00 00 09 09 72 65 74 | 75 72 6e 28 45 52 52 4f |.....ret|urn(ERRO|
|00000f50| 52 29 3b 0d 0a 00 00 00 | 00 09 7d 0d 0a 00 00 00 |R);.....|..}.....|
|00000f60| 00 23 65 6e 64 69 66 0d | 0a 00 00 00 00 0d 0a 00 |.#endif.|........|
|00000f70| 00 00 00 09 77 68 69 6c | 65 20 28 6e 2d 2d 29 20 |....whil|e (n--) |
|00000f80| 77 72 69 74 65 5f 70 69 | 78 65 6c 28 78 2c 79 2b |write_pi|xel(x,y+|
|00000f90| 2b 2c 2a 62 70 2b 2b 29 | 3b 0d 0a 00 00 00 00 09 |+,*bp++)|;.......|
|00000fa0| 72 65 74 75 72 6e 28 4f | 4b 29 3b 0d 0a 00 00 00 |return(O|K);.....|
|00000fb0| 00 7d 0d 0a 00 00 00 00 | 0d 0a 00 00 00 00 2f 2a |.}......|....../*|
|00000fc0| 20 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d | =======|========|
|00000fd0| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|00000fe0| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|00000ff0| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|00001000| 3d 20 2a 2f 0d 0a 00 00 | 00 00 0d 0a 00 00 00 00 |= */....|........|
|00001010| 2f 2a 20 72 65 61 64 5f | 61 72 65 61 20 3d 20 52 |/* read_|area = R|
|00001020| 65 61 64 20 61 6e 20 61 | 72 65 61 20 6f 66 20 70 |ead an a|rea of p|
|00001030| 69 78 65 6c 73 20 69 6e | 74 6f 20 62 75 66 66 65 |ixels in|to buffe|
|00001040| 72 20 62 70 2c 20 73 74 | 61 72 74 69 6e 67 20 61 |r bp, st|arting a|
|00001050| 74 0d 0a 00 00 00 00 20 | 2a 20 6c 6f 63 61 74 69 |t...... |* locati|
|00001060| 6f 6e 20 78 2c 79 20 61 | 6e 64 20 6f 66 20 6c 65 |on x,y a|nd of le|
|00001070| 6e 67 74 68 20 6e 2e 0d | 0a 00 00 00 00 20 2a 2f |ngth n..|..... */|
|00001080| 0d 0a 00 00 00 00 69 6e | 74 20 72 65 61 64 5f 61 |......in|t read_a|
|00001090| 72 65 61 28 78 2c 79 2c | 64 78 2c 64 79 2c 62 70 |rea(x,y,|dx,dy,bp|
|000010a0| 29 0d 0a 00 00 00 00 69 | 6e 74 20 78 2c 79 3b 09 |)......i|nt x,y;.|
|000010b0| 09 09 2f 2a 20 53 63 72 | 65 65 6e 20 73 74 61 72 |../* Scr|een star|
|000010c0| 74 69 6e 67 20 6c 6f 63 | 61 74 69 6f 6e 20 2a 2f |ting loc|ation */|
|000010d0| 0d 0a 00 00 00 00 69 6e | 74 20 64 78 2c 64 79 3b |......in|t dx,dy;|
|000010e0| 09 09 09 2f 2a 20 53 69 | 7a 65 20 6f 66 20 61 72 |.../* Si|ze of ar|
|000010f0| 65 61 20 2a 2f 0d 0a 00 | 00 00 00 72 65 67 69 73 |ea */...|...regis|
|00001100| 74 65 72 20 50 49 58 45 | 4c 20 2a 62 70 3b 09 09 |ter PIXE|L *bp;..|
|00001110| 2f 2a 20 50 6f 69 6e 74 | 65 72 20 74 6f 20 70 69 |/* Point|er to pi|
|00001120| 78 65 6c 20 62 75 66 66 | 65 72 20 2a 2f 0d 0a 00 |xel buff|er */...|
|00001130| 00 00 00 7b 0d 0a 00 00 | 00 00 0d 0a 00 00 00 00 |...{....|........|
|00001140| 23 69 66 64 65 66 20 43 | 48 45 43 4b 0d 0a 00 00 |#ifdef C|HECK....|
|00001150| 00 00 09 69 66 20 28 63 | 68 65 63 6b 5f 61 72 65 |...if (c|heck_are|
|00001160| 61 28 78 2c 79 2c 64 78 | 2c 64 79 2c 22 3c 72 65 |a(x,y,dx|,dy,"<re|
|00001170| 61 64 5f 61 72 65 61 3e | 22 29 20 3d 3d 20 45 52 |ad_area>|") == ER|
|00001180| 52 4f 52 29 0d 0a 00 00 | 00 00 09 09 72 65 74 75 |ROR)....|....retu|
|00001190| 72 6e 28 45 52 52 4f 52 | 29 3b 0d 0a 00 00 00 00 |rn(ERROR|);......|
|000011a0| 23 65 6e 64 69 66 0d 0a | 00 00 00 00 09 77 68 69 |#endif..|.....whi|
|000011b0| 6c 65 20 28 64 79 2d 2d | 29 20 7b 0d 0a 00 00 00 |le (dy--|) {.....|
|000011c0| 00 09 09 72 65 61 64 5f | 68 6c 69 6e 65 28 78 2c |...read_|hline(x,|
|000011d0| 79 2b 2b 2c 64 78 2c 62 | 70 29 3b 0d 0a 00 00 00 |y++,dx,b|p);.....|
|000011e0| 00 09 09 62 70 20 2b 3d | 20 64 78 3b 0d 0a 00 00 |...bp +=| dx;....|
|000011f0| 00 00 09 7d 0d 0a 00 00 | 00 00 09 72 65 74 75 72 |...}....|...retur|
|00001200| 6e 28 4f 4b 29 3b 0d 0a | 00 00 00 00 7d 0d 0a 00 |n(OK);..|....}...|
|00001210| 00 00 00 0d 0a 00 00 00 | 00 2f 2a 20 3d 3d 3d 3d |........|./* ====|
|00001220| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|00001230| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|00001240| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|00001250| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 20 2a 2f 0d |========|==== */.|
|00001260| 0a 00 00 00 00 0d 0a 00 | 00 00 00 2f 2a 20 77 72 |........|.../* wr|
|00001270| 69 74 65 5f 61 72 65 61 | 20 3d 20 57 72 69 74 65 |ite_area| = Write|
|00001280| 20 74 68 65 20 63 6f 6e | 74 65 6e 74 73 20 6f 66 | the con|tents of|
|00001290| 20 62 75 66 66 65 72 20 | 62 70 20 69 6e 74 6f 20 | buffer |bp into |
|000012a0| 74 68 65 20 69 6d 61 67 | 65 20 61 72 65 61 0d 0a |the imag|e area..|
|000012b0| 00 00 00 00 20 2a 20 73 | 74 61 72 74 69 6e 67 20 |.... * s|tarting |
|000012c0| 61 74 20 78 2c 79 20 61 | 6e 64 20 6f 66 20 73 69 |at x,y a|nd of si|
|000012d0| 7a 65 20 64 78 2c 64 79 | 2e 0d 0a 00 00 00 00 20 |ze dx,dy|....... |
|000012e0| 2a 2f 0d 0a 00 00 00 00 | 77 72 69 74 65 5f 61 72 |*/......|write_ar|
|000012f0| 65 61 28 78 2c 79 2c 64 | 78 2c 64 79 2c 62 70 29 |ea(x,y,d|x,dy,bp)|
|00001300| 0d 0a 00 00 00 00 69 6e | 74 20 78 2c 79 3b 09 09 |......in|t x,y;..|
|00001310| 09 2f 2a 20 53 63 72 65 | 65 6e 20 73 74 61 72 74 |./* Scre|en start|
|00001320| 69 6e 67 20 6c 6f 63 61 | 74 69 6f 6e 20 2a 2f 0d |ing loca|tion */.|
|00001330| 0a 00 00 00 00 69 6e 74 | 20 64 78 2c 64 79 3b 09 |.....int| dx,dy;.|
|00001340| 09 09 2f 2a 20 53 69 7a | 65 20 6f 66 20 61 72 65 |../* Siz|e of are|
|00001350| 61 20 2a 2f 0d 0a 00 00 | 00 00 72 65 67 69 73 74 |a */....|..regist|
|00001360| 65 72 20 50 49 58 45 4c | 20 2a 62 70 3b 09 09 2f |er PIXEL| *bp;../|
|00001370| 2a 20 50 6f 69 6e 74 65 | 72 20 74 6f 20 70 69 78 |* Pointe|r to pix|
|00001380| 65 6c 20 62 75 66 66 70 | 65 72 20 2a 2f 0d 0a 00 |el buffp|er */...|
|00001390| 00 00 00 7b 0d 0a 00 00 | 00 00 23 69 66 64 65 66 |...{....|..#ifdef|
|000013a0| 20 43 48 45 43 4b 0d 0a | 00 00 00 00 09 69 66 20 | CHECK..|.....if |
|000013b0| 28 63 68 65 63 6b 5f 61 | 72 65 61 28 78 2c 79 2c |(check_a|rea(x,y,|
|000013c0| 64 78 2c 64 79 2c 22 3c | 77 72 69 74 65 5f 61 72 |dx,dy,"<|write_ar|
|000013d0| 65 61 3e 22 29 20 3d 3d | 20 45 52 52 4f 52 29 0d |ea>") ==| ERROR).|
|000013e0| 0a 00 00 00 00 09 09 72 | 65 74 75 72 6e 28 45 52 |.......r|eturn(ER|
|000013f0| 52 4f 52 29 3b 0d 0a 00 | 00 00 00 23 65 6e 64 69 |ROR);...|...#endi|
|00001400| 66 0d 0a 00 00 00 00 09 | 77 68 69 6c 65 20 28 64 |f.......|while (d|
|00001410| 79 2d 2d 29 20 7b 0d 0a | 00 00 00 00 09 09 77 72 |y--) {..|......wr|
|00001420| 69 74 65 5f 68 6c 69 6e | 65 28 78 2c 79 2b 2b 2c |ite_hlin|e(x,y++,|
|00001430| 64 78 2c 62 70 29 3b 0d | 0a 00 00 00 00 09 09 62 |dx,bp);.|.......b|
|00001440| 70 20 2b 3d 20 64 78 3b | 0d 0a 00 00 00 00 09 7d |p += dx;|.......}|
|00001450| 0d 0a 00 00 00 00 0d 0a | 00 00 00 00 09 72 65 74 |........|.....ret|
|00001460| 75 72 6e 28 4f 4b 29 3b | 0d 0a 00 00 00 00 7d 0d |urn(OK);|......}.|
|00001470| 0a 00 00 00 00 0d 0a 00 | 00 00 00 2f 2a 20 3d 3d |........|.../* ==|
|00001480| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|00001490| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|000014a0| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|000014b0| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 20 2a |========|====== *|
|000014c0| 2f 0d 0a 00 00 00 00 0d | 0a 00 00 00 00 2f 2a 20 |/.......|...../* |
|000014d0| 63 6f 70 79 5f 61 72 65 | 61 20 3d 20 63 6f 70 79 |copy_are|a = copy|
|000014e0| 20 74 68 65 20 69 6d 61 | 67 65 20 6d 65 6d 6f 72 | the ima|ge memor|
|000014f0| 79 20 61 72 65 61 20 73 | 74 61 72 74 69 6e 67 20 |y area s|tarting |
|00001500| 61 74 20 78 2c 79 20 61 | 6e 64 20 6f 66 20 73 69 |at x,y a|nd of si|
|00001510| 7a 65 0d 0a 00 00 00 00 | 20 2a 20 64 78 2c 64 79 |ze......| * dx,dy|
|00001520| 20 69 6e 74 6f 20 74 68 | 65 20 61 72 65 61 20 73 | into th|e area s|
|00001530| 74 61 72 74 69 6e 67 20 | 61 74 20 78 64 2c 79 64 |tarting |at xd,yd|
|00001540| 20 61 6e 64 20 6f 66 20 | 73 69 7a 65 20 64 78 64 | and of |size dxd|
|00001550| 2c 64 79 64 2e 0d 0a 00 | 00 00 00 20 2a 2f 0d 0a |,dyd....|... */..|
|00001560| 00 00 00 00 63 6f 70 79 | 5f 61 72 65 61 28 78 2c |....copy|_area(x,|
|00001570| 79 2c 64 78 2c 64 79 2c | 78 64 2c 79 64 2c 64 78 |y,dx,dy,|xd,yd,dx|
|00001580| 64 2c 64 79 64 29 0d 0a | 00 00 00 00 69 6e 74 20 |d,dyd)..|....int |
|00001590| 78 2c 79 3b 09 09 2f 2a | 20 53 74 61 72 74 20 6f |x,y;../*| Start o|
|000015a0| 66 20 73 6f 75 72 63 65 | 20 2a 2f 0d 0a 00 00 00 |f source| */.....|
|000015b0| 00 69 6e 74 20 64 78 2c | 64 79 3b 09 09 2f 2a 20 |.int dx,|dy;../* |
|000015c0| 53 69 7a 65 20 6f 66 20 | 63 6f 70 79 20 2a 2f 0d |Size of |copy */.|
|000015d0| 0a 00 00 00 00 69 6e 74 | 20 78 64 2c 79 64 3b 09 |.....int| xd,yd;.|
|000015e0| 09 2f 2a 20 44 65 73 74 | 69 6e 61 74 69 6f 6e 20 |./* Dest|ination |
|000015f0| 73 74 61 72 74 20 2a 2f | 0d 0a 00 00 00 00 69 6e |start */|......in|
|00001600| 74 20 64 78 64 2c 64 79 | 64 3b 09 09 2f 2a 20 44 |t dxd,dy|d;../* D|
|00001610| 65 73 74 69 6e 61 74 69 | 6f 6e 20 73 69 7a 65 20 |estinati|on size |
|00001620| 2a 2f 0d 0a 00 00 00 00 | 7b 0d 0a 00 00 00 00 09 |*/......|{.......|
|00001630| 50 49 58 45 4c 20 2a 62 | 70 2c 20 2a 62 75 66 3b |PIXEL *b|p, *buf;|
|00001640| 0d 0a 00 00 00 00 0d 0a | 00 00 00 00 23 69 66 64 |........|....#ifd|
|00001650| 65 66 20 43 48 45 43 4b | 0d 0a 00 00 00 00 09 69 |ef CHECK|.......i|
|00001660| 66 20 28 63 68 65 63 6b | 5f 61 72 65 61 28 78 2c |f (check|_area(x,|
|00001670| 79 2c 64 78 2c 64 79 2c | 22 3c 63 6f 70 79 5f 61 |y,dx,dy,|"<copy_a|
|00001680| 72 65 61 3e 20 53 6f 75 | 72 63 65 22 29 20 3d 3d |rea> Sou|rce") ==|
|00001690| 20 45 52 52 4f 52 29 0d | 0a 00 00 00 00 09 09 72 | ERROR).|.......r|
|000016a0| 65 74 75 72 6e 28 45 52 | 52 4f 52 29 3b 0d 0a 00 |eturn(ER|ROR);...|
|000016b0| 00 00 00 09 69 66 20 28 | 63 68 65 63 6b 5f 61 72 |....if (|check_ar|
|000016c0| 65 61 28 78 64 2c 79 64 | 2c 64 78 64 2c 64 79 64 |ea(xd,yd|,dxd,dyd|
|000016d0| 2c 22 3c 63 6f 70 79 5f | 61 72 65 61 3e 20 44 65 |,"<copy_|area> De|
|000016e0| 73 74 69 6e 61 74 69 6f | 6e 22 29 3d 3d 45 52 52 |stinatio|n")==ERR|
|000016f0| 4f 52 29 0d 0a 00 00 00 | 00 09 09 72 65 74 75 72 |OR).....|...retur|
|00001700| 6e 28 45 52 52 4f 52 29 | 3b 0d 0a 00 00 00 00 23 |n(ERROR)|;......#|
|00001710| 65 6e 64 69 66 0d 0a 00 | 00 00 00 0d 0a 00 00 00 |endif...|........|
|00001720| 00 2f 2a 20 53 65 6c 65 | 63 74 20 74 68 65 20 73 |./* Sele|ct the s|
|00001730| 6d 61 6c 6c 65 72 20 6f | 66 20 74 68 65 20 74 77 |maller o|f the tw|
|00001740| 6f 20 61 72 65 61 20 73 | 69 7a 65 73 20 2a 2f 0d |o area s|izes */.|
|00001750| 0a 00 00 00 00 09 69 66 | 20 28 64 78 64 20 3c 20 |......if| (dxd < |
|00001760| 64 78 29 20 64 78 20 3d | 20 64 78 64 3b 0d 0a 00 |dx) dx =| dxd;...|
|00001770| 00 00 00 09 69 66 20 28 | 64 79 64 20 3c 20 64 79 |....if (|dyd < dy|
|00001780| 29 20 64 79 20 3d 20 64 | 79 64 3b 0d 0a 00 00 00 |) dy = d|yd;.....|
|00001790| 00 0d 0a 00 00 00 00 2f | 2a 20 43 68 65 63 6b 20 |......./|* Check |
|000017a0| 74 68 61 74 20 79 6f 75 | 20 77 6f 6e 27 74 20 72 |that you| won't r|
|000017b0| 75 6e 20 6f 66 66 20 74 | 68 65 20 66 72 61 6d 65 |un off t|he frame|
|000017c0| 20 6d 65 6d 6f 72 79 20 | 2a 2f 0d 0a 00 00 00 00 | memory |*/......|
|000017d0| 09 69 66 20 28 28 79 64 | 20 2b 20 64 79 29 20 3e |.if ((yd| + dy) >|
|000017e0| 20 59 53 49 5a 45 29 20 | 64 79 20 3d 20 59 53 49 | YSIZE) |dy = YSI|
|000017f0| 5a 45 20 2d 20 79 64 3b | 0d 0a 00 00 00 00 09 69 |ZE - yd;|.......i|
|00001800| 66 20 28 28 78 64 20 2b | 20 64 78 29 20 3e 20 58 |f ((xd +| dx) > X|
|00001810| 53 49 5a 45 29 20 64 78 | 20 3d 20 58 53 49 5a 45 |SIZE) dx| = XSIZE|
|00001820| 20 2d 20 78 64 3b 0d 0a | 00 00 00 00 0d 0a 00 00 | - xd;..|........|
|00001830| 00 00 2f 2a 20 41 6c 6c | 6f 63 61 74 65 20 61 20 |../* All|ocate a |
|00001840| 62 75 66 66 65 72 20 2a | 2f 0d 0a 00 00 00 00 09 |buffer *|/.......|
|00001850| 62 70 20 3d 20 62 75 66 | 20 3d 20 28 50 49 58 45 |bp = buf| = (PIXE|
|00001860| 4c 20 2a 29 6d 61 6c 6c | 6f 63 28 64 78 2a 73 69 |L *)mall|oc(dx*si|
|00001870| 7a 65 6f 66 28 50 49 58 | 45 4c 29 29 3b 0d 0a 00 |zeof(PIX|EL));...|
|00001880| 00 00 00 0d 0a 00 00 00 | 00 2f 2a 20 49 66 20 74 |........|./* If t|
|00001890| 68 65 20 73 6f 75 72 63 | 65 20 69 73 20 61 62 6f |he sourc|e is abo|
|000018a0| 76 65 20 74 68 65 20 64 | 65 73 74 69 6e 61 74 69 |ve the d|estinati|
|000018b0| 6f 6e 2c 20 63 6f 70 79 | 20 74 6f 70 20 64 6f 77 |on, copy| top dow|
|000018c0| 6e 20 2a 2f 0d 0a 00 00 | 00 00 09 69 66 20 28 79 |n */....|...if (y|
|000018d0| 20 3e 3d 20 79 64 29 20 | 7b 0d 0a 00 00 00 00 09 | >= yd) |{.......|
|000018e0| 09 77 68 69 6c 65 28 64 | 79 2d 2d 29 20 7b 0d 0a |.while(d|y--) {..|
|000018f0| 00 00 00 00 09 09 09 72 | 65 61 64 5f 68 6c 69 6e |.......r|ead_hlin|
|00001900| 65 28 78 2c 79 2b 2b 2c | 64 78 2c 62 70 29 3b 0d |e(x,y++,|dx,bp);.|
|00001910| 0a 00 00 00 00 09 09 09 | 77 72 69 74 65 5f 68 6c |........|write_hl|
|00001920| 69 6e 65 28 78 64 2c 79 | 64 2b 2b 2c 64 78 2c 62 |ine(xd,y|d++,dx,b|
|00001930| 70 29 3b 0d 0a 00 00 00 | 00 09 09 7d 0d 0a 00 00 |p);.....|...}....|
|00001940| 00 00 09 7d 0d 0a 00 00 | 00 00 2f 2a 20 45 6c 73 |...}....|../* Els|
|00001950| 65 20 69 66 20 64 65 73 | 74 69 6e 61 74 69 6f 6e |e if des|tination|
|00001960| 20 69 73 20 61 62 6f 76 | 65 20 73 6f 75 72 63 65 | is abov|e source|
|00001970| 2c 20 63 6f 70 79 20 62 | 6f 74 74 6f 6d 20 75 70 |, copy b|ottom up|
|00001980| 20 2a 2f 0d 0a 00 00 00 | 00 09 65 6c 73 65 20 7b | */.....|..else {|
|00001990| 0d 0a 00 00 00 00 09 09 | 79 20 2b 3d 20 64 79 2d |........|y += dy-|
|000019a0| 31 3b 20 20 79 64 20 2b | 3d 20 64 79 2d 31 3b 0d |1; yd +|= dy-1;.|
|000019b0| 0a 00 00 00 00 09 09 77 | 68 69 6c 65 28 64 79 2d |.......w|hile(dy-|
|000019c0| 2d 29 20 7b 0d 0a 00 00 | 00 00 09 09 09 72 65 61 |-) {....|.....rea|
|000019d0| 64 5f 68 6c 69 6e 65 28 | 78 2c 79 2d 2d 2c 64 78 |d_hline(|x,y--,dx|
|000019e0| 2c 62 70 29 3b 0d 0a 00 | 00 00 00 09 09 09 77 72 |,bp);...|......wr|
|000019f0| 69 74 65 5f 68 6c 69 6e | 65 28 78 2c 79 64 2d 2d |ite_hlin|e(x,yd--|
|00001a00| 2c 64 78 2c 62 70 29 3b | 0d 0a 00 00 00 00 09 09 |,dx,bp);|........|
|00001a10| 7d 0d 0a 00 00 00 00 09 | 7d 0d 0a 00 00 00 00 0d |}.......|}.......|
|00001a20| 0a 00 00 00 00 09 66 72 | 65 65 28 62 75 66 29 3b |......fr|ee(buf);|
|00001a30| 0d 0a 00 00 00 00 09 72 | 65 74 75 72 6e 28 4f 4b |.......r|eturn(OK|
|00001a40| 29 3b 0d 0a 00 00 00 00 | 7d 0d 0a 00 00 00 00 0d |);......|}.......|
|00001a50| 0a 00 00 00 00 2f 2a 20 | 3d 3d 3d 3d 3d 3d 3d 3d |...../* |========|
|00001a60| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 20 45 52 52 4f |========|=== ERRO|
|00001a70| 52 20 43 48 45 43 4b 49 | 4e 47 20 3d 3d 3d 3d 3d |R CHECKI|NG =====|
|00001a80| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 3d 3d 3d 3d 3d 3d |========|========|
|00001a90| 3d 3d 3d 3d 3d 3d 3d 20 | 2a 2f 0d 0a 00 00 00 00 |======= |*/......|
|00001aa0| 0d 0a 00 00 00 00 2f 2a | 20 63 68 65 63 6b 5f 61 |....../*| check_a|
|00001ab0| 72 65 61 20 3d 20 43 68 | 65 63 6b 73 20 74 68 61 |rea = Ch|ecks tha|
|00001ac0| 74 20 61 72 65 61 20 73 | 74 61 72 74 69 6e 67 20 |t area s|tarting |
|00001ad0| 61 74 20 78 2c 79 20 61 | 6e 64 20 6f 66 20 73 69 |at x,y a|nd of si|
|00001ae0| 7a 65 20 64 78 2c 64 79 | 20 77 69 6c 6c 20 66 69 |ze dx,dy| will fi|
|00001af0| 74 0d 0a 00 00 00 00 20 | 2a 20 69 6e 74 6f 20 74 |t...... |* into t|
|00001b00| 68 65 20 69 6d 61 67 65 | 20 6d 65 6d 6f 72 79 20 |he image| memory |
|00001b10| 73 69 7a 65 2c 20 61 73 | 20 64 65 66 69 6e 65 64 |size, as| defined|
|00001b20| 20 62 79 20 58 53 54 41 | 52 54 2c 20 59 53 54 41 | by XSTA|RT, YSTA|
|00001b30| 52 54 2c 20 58 53 49 5a | 45 2c 20 59 53 49 5a 45 |RT, XSIZ|E, YSIZE|
|00001b40| 0d 0a 00 00 00 00 20 2a | 20 69 6e 20 73 69 6d 70 |...... *| in simp|
|00001b50| 70 2e 68 20 20 43 68 65 | 63 6b 20 61 6c 6c 20 76 |p.h Che|ck all v|
|00001b60| 61 6c 75 65 73 20 62 65 | 66 6f 72 65 20 72 65 74 |alues be|fore ret|
|00001b70| 75 72 6e 69 6e 67 2e 0d | 0a 00 00 00 00 20 2a 2f |urning..|..... */|
|00001b80| 0d 0a 00 00 00 00 23 69 | 66 64 65 66 20 43 48 45 |......#i|fdef CHE|
|00001b90| 43 4b 0d 0a 00 00 00 00 | 69 6e 74 20 63 68 65 63 |CK......|int chec|
|00001ba0| 6b 5f 61 72 65 61 28 78 | 2c 79 2c 64 78 2c 64 79 |k_area(x|,y,dx,dy|
|00001bb0| 2c 73 29 0d 0a 00 00 00 | 00 69 6e 74 20 78 2c 79 |,s).....|.int x,y|
|00001bc0| 3b 09 2f 2a 20 53 74 61 | 72 74 20 6f 66 20 61 72 |;./* Sta|rt of ar|
|00001bd0| 65 61 20 2a 2f 0d 0a 00 | 00 00 00 69 6e 74 20 64 |ea */...|...int d|
|00001be0| 78 2c 64 79 3b 09 2f 2a | 20 53 69 7a 65 20 6f 66 |x,dy;./*| Size of|
|00001bf0| 20 61 72 65 61 20 2a 2f | 0d 0a 00 00 00 00 63 68 | area */|......ch|
|00001c00| 61 72 20 2a 73 3b 09 2f | 2a 20 53 74 72 69 6e 67 |ar *s;./|* String|
|00001c10| 20 74 6f 20 70 72 65 70 | 65 6e 64 20 74 6f 20 65 | to prep|end to e|
|00001c20| 72 72 6f 72 20 73 74 61 | 74 65 6d 65 6e 74 73 20 |rror sta|tements |
|00001c30| 2a 2f 0d 0a 00 00 00 00 | 7b 0d 0a 00 00 00 00 09 |*/......|{.......|
|00001c40| 69 6e 74 20 66 6c 61 67 | 3b 0d 0a 00 00 00 00 0d |int flag|;.......|
|00001c50| 0a 00 00 00 00 09 66 6c | 61 67 20 3d 20 4f 4b 3b |......fl|ag = OK;|
|00001c60| 0d 0a 00 00 00 00 0d 0a | 00 00 00 00 2f 2a 20 53 |........|..../* S|
|00001c70| 74 61 72 74 69 6e 67 20 | 58 20 2a 2f 0d 0a 00 00 |tarting |X */....|
|00001c80| 00 00 09 69 66 20 28 28 | 78 20 3c 20 58 53 54 41 |...if ((|x < XSTA|
|00001c90| 52 54 29 20 7c 7c 20 28 | 78 20 3e 20 58 45 4e 44 |RT) || (|x > XEND|
|00001ca0| 29 29 20 7b 0d 0a 00 00 | 00 00 09 09 70 72 69 6e |)) {....|....prin|
|00001cb0| 74 66 28 22 25 73 20 61 | 72 65 61 20 58 20 61 64 |tf("%s a|rea X ad|
|00001cc0| 64 72 65 73 73 20 6f 75 | 74 20 6f 66 20 72 61 6e |dress ou|t of ran|
|00001cd0| 67 65 21 5c 6e 22 2c 73 | 29 3b 0d 0a 00 00 00 00 |ge!\n",s|);......|
|00001ce0| 09 09 66 6c 61 67 20 3d | 20 45 52 52 4f 52 3b 0d |..flag =| ERROR;.|
|00001cf0| 0a 00 00 00 00 09 7d 0d | 0a 00 00 00 00 2f 2a 20 |......}.|...../* |
|00001d00| 53 74 61 72 74 69 6e 67 | 20 59 20 2a 2f 0d 0a 00 |Starting| Y */...|
|00001d10| 00 00 00 09 69 66 20 28 | 28 79 20 3c 20 59 53 54 |....if (|(y < YST|
|00001d20| 41 52 54 29 20 7c 7c 20 | 28 79 20 3e 20 59 45 4e |ART) || |(y > YEN|
|00001d30| 44 29 29 20 7b 0d 0a 00 | 00 00 00 09 09 70 72 69 |D)) {...|.....pri|
|00001d40| 6e 74 66 28 22 25 73 20 | 61 72 65 61 20 59 20 61 |ntf("%s |area Y a|
|00001d50| 64 64 72 65 73 73 20 6f | 75 74 20 6f 66 20 72 61 |ddress o|ut of ra|
|00001d60| 6e 67 65 21 5c 6e 22 2c | 73 29 3b 0d 0a 00 00 00 |nge!\n",|s);.....|
|00001d70| 00 09 09 66 6c 61 67 20 | 3d 20 45 52 52 4f 52 3b |...flag |= ERROR;|
|00001d80| 0d 0a 00 00 00 00 09 7d | 0d 0a 00 00 00 00 2f 2a |.......}|....../*|
|00001d90| 20 58 20 73 69 7a 65 20 | 2a 2f 0d 0a 00 00 00 00 | X size |*/......|
|00001da0| 09 69 66 20 28 28 64 78 | 20 3c 20 30 29 20 7c 7c |.if ((dx| < 0) |||
|00001db0| 20 28 64 78 20 3e 20 58 | 53 49 5a 45 2d 78 29 29 | (dx > X|SIZE-x))|
|00001dc0| 20 7b 0d 0a 00 00 00 00 | 09 09 70 72 69 6e 74 66 | {......|..printf|
|00001dd0| 28 22 25 73 20 61 72 65 | 61 20 58 20 73 69 7a 65 |("%s are|a X size|
|00001de0| 20 6f 75 74 20 6f 66 20 | 72 61 6e 67 65 21 5c 6e | out of |range!\n|
|00001df0| 22 2c 73 29 3b 0d 0a 00 | 00 00 00 09 09 66 6c 61 |",s);...|.....fla|
|00001e00| 67 20 3d 20 45 52 52 4f | 52 3b 0d 0a 00 00 00 00 |g = ERRO|R;......|
|00001e10| 09 7d 0d 0a 00 00 00 00 | 2f 2a 20 59 20 73 69 7a |.}......|/* Y siz|
|00001e20| 65 20 2a 2f 0d 0a 00 00 | 00 00 09 69 66 20 28 28 |e */....|...if ((|
|00001e30| 64 79 20 3c 20 30 29 20 | 7c 7c 20 28 64 79 20 3e |dy < 0) ||| (dy >|
|00001e40| 20 59 53 49 5a 45 2d 79 | 29 29 20 7b 0d 0a 00 00 | YSIZE-y|)) {....|
|00001e50| 00 00 09 09 70 72 69 6e | 74 66 28 22 25 73 20 61 |....prin|tf("%s a|
|00001e60| 72 65 61 20 59 20 73 69 | 7a 65 20 6f 75 74 20 6f |rea Y si|ze out o|
|00001e70| 66 20 72 61 6e 67 65 21 | 5c 6e 22 2c 73 29 3b 0d |f range!|\n",s);.|
|00001e80| 0a 00 00 00 00 09 09 66 | 6c 61 67 20 3d 20 45 52 |.......f|lag = ER|
|00001e90| 52 4f 52 3b 0d 0a 00 00 | 00 00 09 7d 0d 0a 00 00 |ROR;....|...}....|
|00001ea0| 00 00 0d 0a 00 00 00 00 | 09 72 65 74 75 72 6e 28 |........|.return(|
|00001eb0| 66 6c 61 67 29 3b 0d 0a | 00 00 00 00 7d 0d 0a 00 |flag);..|....}...|
|00001ec0| 00 00 00 23 65 6e 64 69 | 66 0d 0a 00 00 00 00 0d |...#endi|f.......|
|00001ed0| 0a 00 00 00 00 2f 2a 20 | 3d 3d 3d 3d 3d 3d 3d 3d |...../* |========|
|00001ee0| 3d 3d 3d 3d 3d 3d 3d 3d | 20 45 6e 64 20 6f 66 20 |========| End of |
|00001ef0| 73 69 6d 70 72 69 6d 2e | 63 20 3d 3d 3d 3d 3d 3d |simprim.|c ======|
|00001f00| 3d 3d 3d 3d 3d 3d 3d 3d | 3d 3d 20 2a 2f 0d 0a 00 |========|== */...|
|00001f10| 00 00 00 0d 0a 00 00 00 | 00 2f 2a 20 3c 2d 2d 20 |........|./* <-- |
|00001f20| 46 49 4c 45 20 42 52 45 | 41 4b 20 2d 2d 3e 20 2a |FILE BRE|AK --> *|
|00001f30| 2f 0d 0a 00 00 00 00 25 | 20 1a 00 00 7d 0d 0a 00 |/......%| ...}...|
|00001f40| 00 00 00 23 65 6e 64 69 | 66 0d 0a 00 00 00 00 0d |...#endi|f.......|
|00001f50| 0a 00 00 00 00 2f 2a 20 | 3d 3d 3d 3d 3d 3d 3d 3d |...../* |========|
|00001f60| 3d 3d 3d 3d 3d 3d 3d 3d | 20 45 6e 64 20 6f 66 20 |========| End of |
|00001f70| 73 69 6d 70 72 69 6d 2e | 63 20 3d 3d 3d 3d 3d 3d |simprim.|c ======|
+--------+-------------------------+-------------------------+--------+--------+